Apache Flink-এ Watermark এবং Event Time Processing হলো স্ট্রিম প্রসেসিং-এর খুব গুরুত্বপূর্ণ কনসেপ্ট, বিশেষ করে real-time data processing এর ক্ষেত্রে। Flink এমন ডেটা স্ট্রিম নিয়ে কাজ করতে পারে যেগুলো event-driven এবং যেগুলোর events কোনো নির্দিষ্ট সময়ে ঘটে। নিচে এই দুইটি বিষয় বিস্তারিতভাবে ব্যাখ্যা করা হলো।
Event Time হলো সেই সময় যখন একটি ইভেন্ট আসলেই ঘটেছিল। Flink-এ event time নির্ভর করে স্ট্রিমে থাকা ইভেন্টগুলোর টাইমস্ট্যাম্পের উপর, যা মূলত সোর্স থেকেই আসতে পারে। Event time প্রসেসিং বিশেষ করে real-time analytics এবং latency-sensitive অ্যাপ্লিকেশনগুলোর ক্ষেত্রে খুবই কার্যকর, কারণ এটি স্ট্রিমে আসা ইভেন্টগুলোর আসল টাইমস্ট্যাম্পকে ভিত্তি করে প্রসেসিং করে, ইভেন্টগুলি স্ট্রিমে আসার টাইম বা প্রসেসিং টাইমের উপর নির্ভর করে না।
Watermark হলো একটি মেকানিজম যা Flink-কে স্ট্রিমের event time ট্র্যাক করতে সহায়তা করে। Watermark স্ট্রিমের মধ্য দিয়ে প্রবাহিত হয় এবং Flink-কে বলে যে নির্দিষ্ট টাইমস্ট্যাম্প পর্যন্ত ইভেন্টগুলি এসেছে কিনা। Watermark ইভেন্ট টাইম উইন্ডোগুলি প্রসেস করতে এবং লেট ইভেন্টগুলি সনাক্ত করতে ব্যবহৃত হয়।
WatermarkStrategy
API ব্যবহার করে তৈরি করা হয়।Flink এ event time এবং watermark ব্যবহার করার একটি উদাহরণ:
import org.apache.flink.streaming.api.TimeCharacteristic;
import org.apache.flink.streaming.api.datastream.DataStream;
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
import org.apache.flink.streaming.api.windowing.time.Time;
import org.apache.flink.streaming.api.windowing.assigners.TumblingEventTimeWindows;
import org.apache.flink.streaming.api.windowing.triggers.EventTimeTrigger;
import org.apache.flink.api.common.eventtime.WatermarkStrategy;
public class FlinkWatermarkExample {
public static void main(String[] args) throws Exception {
// Execution Environment তৈরি করা
StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
// Event time ব্যবহার করা হবে বলে নির্ধারণ করা
env.setStreamTimeCharacteristic(TimeCharacteristic.EventTime);
// Data stream পড়া এবং Watermark Strategy নির্ধারণ করা
DataStream<Event> events = env
.readTextFile("path/to/events")
.map(new EventParser())
.assignTimestampsAndWatermarks(
WatermarkStrategy
.<Event>forBoundedOutOfOrderness(Duration.ofSeconds(5))
.withTimestampAssigner((event, timestamp) -> event.getTimestamp())
);
// Event time এর উপর ভিত্তি করে উইন্ডো তৈরি করা
events
.keyBy(event -> event.getKey())
.window(TumblingEventTimeWindows.of(Time.minutes(1)))
.trigger(EventTimeTrigger.create())
.process(new CustomWindowFunction())
.print();
env.execute("Event Time Processing Example");
}
}
StreamExecutionEnvironment
তৈরি করা হয়েছে এবং event time নির্ধারণ করা হয়েছে।assignTimestampsAndWatermarks
ব্যবহার করে আমরা একটি watermark strategy নির্ধারণ করেছি যা ইভেন্টগুলির টাইমস্ট্যাম্প নিয়ে কাজ করে এবং ৫ সেকেন্ডের out-of-order ইভেন্ট মেনে নেয়।Flink-এ watermark এর কয়েকটি ধরন রয়েছে:
Apache Flink-এ Watermark এবং Event Time Processing ব্যবহার করে real-time ডেটা প্রসেসিং আরও নির্ভুল এবং সময়ানুগ করা যায়। এটি real-world অ্যাপ্লিকেশনগুলোর জন্য একটি শক্তিশালী টুল, যা stream processing এবং latency-sensitive ডেটা এনালিটিক্স এর জন্য খুবই উপযোগী।
Read more
আমাদের অল-ইন-ওয়ান মোবাইল অ্যাপের মাধ্যমে সীমাহীন শেখার সুযোগ উপভোগ করুন।
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Ducimus nihil, quo, quis minus aspernatur expedita, incidunt facilis aliquid inventore voluptate dolores accusantium laborum labore a dolorum dolore omnis qui? Consequuntur sed facilis repellendus corrupti amet in quibusdam ducimus illo autem, a praesentium.
1 hour ago
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Ducimus nihil, quo, quis minus aspernatur expedita, incidunt facilis aliquid inventore voluptate dolores accusantium laborum labore a dolorum dolore omnis qui? Consequuntur sed facilis repellendus corrupti amet in quibusdam ducimus illo autem, a praesentium.
1 hour ago
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Ducimus nihil, quo, quis minus aspernatur expedita, incidunt facilis aliquid inventore voluptate dolores accusantium laborum labore a dolorum dolore omnis qui? Consequuntur sed facilis repellendus corrupti amet in quibusdam ducimus illo autem, a praesentium.
1 hour ago
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Ducimus nihil, quo, quis minus aspernatur expedita, incidunt facilis aliquid inventore voluptate dolores accusantium laborum labore a dolorum dolore omnis qui? Consequuntur sed facilis repellendus corrupti amet in quibusdam ducimus illo autem, a praesentium.
1 hour ago
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Ducimus nihil, quo, quis minus aspernatur expedita, incidunt facilis aliquid inventore voluptate dolores accusantium laborum labore a dolorum dolore omnis qui? Consequuntur sed facilis repellendus corrupti amet in quibusdam ducimus illo autem, a praesentium.
1 hour ago
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Ducimus nihil, quo, quis minus aspernatur expedita, incidunt facilis aliquid inventore voluptate dolores accusantium laborum labore a dolorum dolore omnis qui? Consequuntur sed facilis repellendus corrupti amet in quibusdam ducimus illo autem, a praesentium.
1 hour ago
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Ducimus nihil, quo, quis minus aspernatur expedita, incidunt facilis aliquid inventore voluptate dolores accusantium laborum labore a dolorum dolore omnis qui? Consequuntur sed facilis repellendus corrupti amet in quibusdam ducimus illo autem, a praesentium.
1 hour ago
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Ducimus nihil, quo, quis minus aspernatur expedita, incidunt facilis aliquid inventore voluptate dolores accusantium laborum labore a dolorum dolore omnis qui? Consequuntur sed facilis repellendus corrupti amet in quibusdam ducimus illo autem, a praesentium.
1 hour ago
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Ducimus nihil, quo, quis minus aspernatur expedita, incidunt facilis aliquid inventore voluptate dolores accusantium laborum labore a dolorum dolore omnis qui? Consequuntur sed facilis repellendus corrupti amet in quibusdam ducimus illo autem, a praesentium.
1 hour ago
Lorem ipsum dolor, sit amet consectetur adipisicing elit. Ducimus nihil, quo, quis minus aspernatur expedita, incidunt facilis aliquid inventore voluptate dolores accusantium laborum labore a dolorum dolore omnis qui? Consequuntur sed facilis repellendus corrupti amet in quibusdam ducimus illo autem, a praesentium.
1 hour ago